home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus 2002 #11 / Amiga Plus CD - 2002 - No. 11.iso / Tools / Development / ncurses-5.3 / ncurses / base / lib_slkset.c < prev    next >
Encoding:
C/C++ Source or Header  |  2002-10-27  |  3.9 KB  |  98 lines

  1. /****************************************************************************
  2.  * Copyright (c) 1998,2000,2001 Free Software Foundation, Inc.              *
  3.  *                                                                          *
  4.  * Permission is hereby granted, free of charge, to any person obtaining a  *
  5.  * copy of this software and associated documentation files (the            *
  6.  * "Software"), to deal in the Software without restriction, including      *
  7.  * without limitation the rights to use, copy, modify, merge, publish,      *
  8.  * distribute, distribute with modifications, sublicense, and/or sell       *
  9.  * copies of the Software, and to permit persons to whom the Software is    *
  10.  * furnished to do so, subject to the following conditions:                 *
  11.  *                                                                          *
  12.  * The above copyright notice and this permission notice shall be included  *
  13.  * in all copies or substantial portions of the Software.                   *
  14.  *                                                                          *
  15.  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
  16.  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
  17.  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
  18.  * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
  19.  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
  20.  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
  21.  * THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
  22.  *                                                                          *
  23.  * Except as contained in this notice, the name(s) of the above copyright   *
  24.  * holders shall not be used in advertising or otherwise to promote the     *
  25.  * sale, use or other dealings in this Software without prior written       *
  26.  * authorization.                                                           *
  27.  ****************************************************************************/
  28.  
  29. /****************************************************************************
  30.  *  Author: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995               *
  31.  *     and: Eric S. Raymond <esr@snark.thyrsus.com>                         *
  32.  ****************************************************************************/
  33.  
  34. /*
  35.  *    lib_slkset.c
  36.  *      Set soft label text.
  37.  */
  38. #include <curses.priv.h>
  39. #include <ctype.h>
  40.  
  41. MODULE_ID("$Id: lib_slkset.c,v 1.7 2001/06/02 22:50:29 skimo Exp $")
  42.  
  43. NCURSES_EXPORT(int)
  44. slk_set(int i, const char *astr, int format)
  45. {
  46.     SLK *slk = SP->_slk;
  47.     size_t len;
  48.     const char *str = astr;
  49.     const char *p;
  50.  
  51.     T((T_CALLED("slk_set(%d, \"%s\", %d)"), i, str, format));
  52.  
  53.     if (slk == NULL || i < 1 || i > slk->labcnt || format < 0 || format > 2)
  54.     returnCode(ERR);
  55.     if (str == NULL)
  56.     str = "";
  57.  
  58.     while (isspace(UChar(*str)))
  59.     str++;            /* skip over leading spaces  */
  60.     p = str;
  61.     while (isprint(UChar(*p)))
  62.     p++;            /* The first non-print stops */
  63.  
  64.     --i;            /* Adjust numbering of labels */
  65.  
  66.     len = (size_t) (p - str);
  67.     if (len > (unsigned) slk->maxlen)
  68.     len = slk->maxlen;
  69.     if (len == 0)
  70.     slk->ent[i].text[0] = 0;
  71.     else
  72.     (void) strncpy(slk->ent[i].text, str, len);
  73.     memset(slk->ent[i].form_text, ' ', (unsigned) slk->maxlen);
  74.     slk->ent[i].text[slk->maxlen] = 0;
  75.     /* len = strlen(slk->ent[i].text); */
  76.  
  77.     switch (format) {
  78.     case 0:            /* left-justified */
  79.     memcpy(slk->ent[i].form_text,
  80.            slk->ent[i].text,
  81.            len);
  82.     break;
  83.     case 1:            /* centered */
  84.     memcpy(slk->ent[i].form_text + (slk->maxlen - len) / 2,
  85.            slk->ent[i].text,
  86.            len);
  87.     break;
  88.     case 2:            /* right-justified */
  89.     memcpy(slk->ent[i].form_text + slk->maxlen - len,
  90.            slk->ent[i].text,
  91.            len);
  92.     break;
  93.     }
  94.     slk->ent[i].form_text[slk->maxlen] = 0;
  95.     slk->ent[i].dirty = TRUE;
  96.     returnCode(OK);
  97. }
  98.